<template>
	<view>
		<!-- 选择收获地址的盒子 -->
		<view class="address-choose-box" v-if="JSON.stringify(address) === '{}'">
			<button type="primary" size="mini" class="btnChooseAddress" @click="chooseAddress">
				请选择收获地址+
			</button>
		</view>

		<!-- 渲染收获信息的盒子 -->
		<view class="address-info-box" v-else @click="chooseAddress">
			<view class="row1">
				<view class="row1-left">
					<view class="username">收货人 : {{ address.userName }}</view>
				</view>
				<view class="row1-right">
					<view class="phone">电话 : {{ address.telNumber }}</view>
					<uni-icons type="arrowright" size="16"></uni-icons>
				</view>
			</view>
			<view class="row2">
				<view class="row2-left">收货地址 : </view>
				<view class="row2-right">{{ addstr }}</view>
			</view>
		</view>

		<!-- 底部的边框线 -->
		<image src="/static/cart_border@2x.png" class="address-border" />
	</view>
</template>

<script>
import { mapState, mapMutations, mapGetters } from 'vuex';

export default {
	name: 'my-address',
	data() {
		return {
			// address: {},
		};
	},
	methods: {
		...mapMutations('m_user', ['updateAddress']),
		// 选择收获地址
		async chooseAddress() {
			const [err, succ] = await uni.chooseAddress().catch((err) => err);

			if (err === null && succ.errMsg === 'chooseAddress:ok') {
				// console.log(succ);
				// this.address = succ;
				// 使用 vuex 中的方法, 并传入参数
				this.updateAddress(succ);
			}

			// 下方的判断还增加对 iphone 系统的判断
			if (
				err &&
				(err.errMsg === 'chooseAddress:fail auth deny' ||
					err.errMsg === 'chooseAddress:fail authorize no response')
			) {
				// console.log('需要重新授权');
				// 通过调用这个方法, 让用户重新授权
				this.reAuth();
			}
		},
		// 让用户重新授权
		async reAuth() {
			const [err2, confirmResult] = uni.showModal({
				title: '提示',
				content: '检测到您没有打开地址权限, 是否去设置打开?',
				confirmText: '确认',
				cancelText: '取消',
			});

			if (err2) return;

			console.log(confirmResult);

			if (confirmResult.cancel) return uni.$showMsg('您取消了地址授权!');
			if (confirmResult.confirm)
				return uni.wx.openSetting({
					success: (settingResult) => {
						if (!settingResult.authSetting['scope.address'])
							return uni.$showMsg('您取消了授权!');
						if (settingResult.authSetting['scope.address'])
							return uni.$showMsg('授权成功!请选择收货地址');
					},
					fail: () => {},
					complete: () => {},
				});
		},
	},
	computed: {
		...mapState('m_user', ['address']),
		...mapGetters('m_user', ['addstr']),
	},
};
</script>

<style lang="scss">
.address-border {
	display: block;
	width: 100%;
	height: 5px;
}
.address-choose-box {
	height: 90px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.address-info-box {
	font-size: 12px;
	height: 90px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 0 5px;
	.row1 {
		display: flex;
		justify-content: space-between;

		.row1-right {
			display: flex;
			justify-content: space-between;
		}
	}
	.row2 {
		display: flex;
		align-items: center;
		margin-top: 10px;
		.row2-left {
			// 文本不换行
			white-space: nowrap;
			margin-right: 5px;
		}
	}
}
</style>
